<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="${package.Mapper}.${table.mapperName}">

<#if enableCache>
    <!-- 开启二级缓存 -->
    <cache type="org.mybatis.caches.ehcache.LoggingEhcache"/>

</#if>
    <!-- 通用查询映射结果 -->
    <resultMap id="BaseResultMap" type="${package.Entity}.${entity}">
<#list table.fields as field>
<#if field.keyFlag><#--生成主键排在第一位-->
        <id column="${field.name?lower_case}" property="${field.propertyName}" />
</#if>
</#list>
<#list table.commonFields as field><#--生成公共字段 -->
        <result column="${field.name?lower_case}" property="${field.propertyName}" />
</#list>
<#list table.fields as field>
<#if !field.keyFlag><#--生成普通字段 -->
        <result column="${field.name?lower_case}" property="${field.propertyName}" />
</#if>
</#list>
    </resultMap>


    <!-- 通用查询结果列 -->
    <sql id="Base_Column_List">
<#list table.commonFields as field>
        ${field.columnName?lower_case},
</#list>
        ${table.fieldNames?lower_case}
    </sql>

    <!-- ${table.comment!}的全部查询 -->
    <select id="queryAll" resultType="${cfg.pageVoPackage}.${entity}Vo">
        select <include refid="Base_Column_List"/>
        from ${table.name?lower_case}
        <where>
            <#-- ----------  BEGIN 字段循环遍历  ---------->
            <#list table.fields as field>
                <#if field.propertyType = "String">
            <if test="${field.propertyName} != null and ${field.propertyName} != ''">
                and ${field.annotationColumnName?lower_case} = <#noparse>#</#noparse>{${field.propertyName}}
            </if>
                <#else>
            <if test="${field.propertyName} != null">
                and ${field.annotationColumnName?lower_case} = <#noparse>#</#noparse>{${field.propertyName}}
            </if>
                </#if>
            </#list>
            <#------------  END 字段循环遍历  ---------->
        </where>
    </select>

    <!-- ${table.comment!}的数量(pagehelper自定义count时将查询方法后加"_COUNT") -->
    <select id="queryAll_COUNT" resultType="Long">
        select count(1)
        from ${table.name?lower_case}
        <where>
            <#-- ----------  BEGIN 字段循环遍历  ---------->
            <#list table.fields as field>
                <#if field.propertyType = "String">
            <if test="${field.propertyName} != null and ${field.propertyName} != ''">
                and ${field.annotationColumnName?lower_case} = <#noparse>#</#noparse>{${field.propertyName}}
            </if>
                <#else>
            <if test="${field.propertyName} != null">
                and ${field.annotationColumnName?lower_case} = <#noparse>#</#noparse>{${field.propertyName}}
            </if>
                </#if>
            </#list>
            <#------------  END 字段循环遍历  ---------->
        </where>
    </select>


</mapper>
